<template>
  <div>
    <upload-excel :on-success="success" />
  </div>
</template>
<script>
import { importEmployee } from '@/api/employees'
export default {
  name: 'ImportIndex', // 组件名称
  components: {// 注册组件
  },
  filters: {// 局部过滤器
  },
  props: {// 父传递数据
  },
  data () { // 数据变量
    return {
    }
  },
  computed: {// 计算属性
  },
  watch: {// 事件侦听
  },
  activated () { // 组件激活时调用的函数
  },
  created () { // data数据加载完毕执行函数
  },
  mounted () { // DOM首次加载完毕时执行的函数
  },
  updated () { // 数据更新时执行的函数,执行多次
  },
  methods: { // 函数定义
    async  success (header, results) {
      // console.log(header.header)
      // console.log(header.results)
      // 需要把他们里面的中文数据导成英文
      // 如果是导入员工
      const userRelations = {
        '入职日期': 'timeOfEntry',
        '手机号': 'mobile',
        '姓名': 'username',
        '转正日期': 'correctionTime',
        '工号': 'workNumber'
      }
      const arr = []
      // 遍历所有的数组
      header.results.forEach(item => {
        // 需要将每一个条数据里面的中文都换成英文
        const userInfo = {}
        Object.keys(item).forEach(key => {
          // key是当前的中文名 找到对应的英文名
          if (userRelations[key] === 'timeOfEntry' || userRelations[key] === 'correctionTime') {
            userInfo[userRelations[key]] = new Date(this.formatDate(item[key], '/')) // 只有这样, 才能入库
            return
          }
          userInfo[userRelations[key]] = item[key]
        })
        // 最终userInfo变成了全是英文
        arr.push(userInfo)
      })
      await importEmployee(arr)
      this.$message.success('导入成功')
      this.$router.back() // 回到上一页
    },
    // 转化excel的日期格式
    formatDate (numb, format) {
      const time = new Date((numb - 1) * 24 * 3600000 + 1)
      time.setYear(time.getFullYear() - 70)
      const year = time.getFullYear() + ''
      const month = time.getMonth() + 1 + ''
      const date = time.getDate() - 1 + ''
      if (format && format.length === 1) {
        return year + format + month + format + date
      }
      return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
    }
  }

}
</script>
<style lang='less' scoped>
</style>
1
